gtest是一个跨平台的(Liunx、Mac OS X、Windows、Android)C++单元测试框架,由google公司发布。gtest是为在不同平台上为编写C++测试而生成的。它提供了丰富的断言、致命和非致命判断、参数化、”死亡测试”等等。
1、如何安装
gtest 是谷歌的 C++ 单元测试框架,下面是安装步骤:
1 | $ git clone https://github.com/google/googletest.git |
安装 gtest 之后,要怎样在 CMake 中使用 gtest 呢?让我们用一个简单的例子演示一下,首先编写项目的 CMakeLists.txt 文件:
1 | cmake_minimum_required (VERSION 2.8) |
接着编写一个简单的单元测试文件 test.cpp:
1 | #include <gtest/gtest.h> |
编译好项目之后,使用命令make test
就可以执行单元测试了:
1 | $ make test |
2、简单的测试
gtest 提供了TEST()
宏,用来定义测试函数:
1 | TEST(test_suite_name, test_case_name) |
在测试函数中,gtest 提供了EXPECT_*
和ASSERT_*
这两种风格的断言:
1 | TEST(MyTest, Add) |
那么这两种断言有什么区别呢?如果ASSERT_*
执行失败了,会导致当前的测试函数立即返回。而EXPECT_*
如果执行失败了,并不会导致测试函数返回。
gtest 提供了 8 个ASSERT_*
断言,分别是: ASSERT_TRUE()
、ASSERT_FALSE()
、ASSERT_EQ()
、ASSERT_NE()
、ASSERT_LT()
、ASSERT_LE()
、ASSERT_GT()
和ASSERT_GE()
。EXPECT_*
的断言同样也有 8 个,分别是: ASSERT_TRUE()
、ASSERT_FALSE()
、EXPECT_EQ()
、EXPECT_NE()
、EXPECT_LT()
、EXPECT_LE()
、EXPECT_GT()
和EXPECT_GE()
。
3、在测试函数之间共享数据
有时候,我们不可避免地会在多个测试函数中操作相同的数据,例如:
1 | TEST(MyTest, Sum) |
一种更好的做法,是将初始化数据在多个测试函数之间共享,并且每个测试函数都拥有这些数据的一份副本,也就是说,在一个测试函数中修改数据,并不会影响到其它测试函数。例如,下面我们定义一个VectorTest
类,它的数据成员vec
可以在多个测试函数之间共享:
1 |
|
可以看到,我们用SetUp()
来初始化资源,如果有必要,还可以使用TearDown()
来释放资源:
1 | class SomeTest : public ::testing::Test |